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. DATA COMPRESSOR The Psion 
Organiser is a microcomputer that can fit in 
your pocket 
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Interface upgrades the Acorn Electron 


PLAYING WITH THE GODS We look at 
an adventure game based on characters from 
Nordic mythology | 
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create an explosion in our Minefield program 4A6 
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advantages of using program modules 5 
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Commodore 64 screen 
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beginnings in the music industry at 46 
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PSION ORGANISER/ HARDWARE ‘ 


DATA COMPRESSOR 


Psion, the company that produced the 
introductory software for the Sinclair 
Spectrum and QL, has moved into the 
hardware market with a pocket computer 
called the ‘Organiser’. The machine’s ability 
to store and retrieve large amounts of data, 
its wide applicability and its ease of use 
make it a remarkable achievement. 


The Psion Organiser, priced at around £100, is the 
size and weight of an electric razor, and at first 
sight it looks like one. A rigid casing envelops the 
calculator-style keyboard, which has 36 small 
buttons. These include the letters of the alphabet 
(the Organiser uses upper case characters only) 
and several Function Keys. The digits 0 to 9, some 


mathematical functions and punctuation symbols 
are all accessed using the Shift key. Above the 
keyboard is a 16-character liquid-crystal display, 
which has an adjustable contrast so that it can be 
read from any angle. Each character is composed 
of a five by eight matrix of dots. 

In the back of the machine are two slots for 
inserting the ‘datapaks’ that provide the long-term 
storage. The Organiser comes fitted with one eight 
Kbyte datapak, although 16 Kbyte sizes are also 
available. | | 

When the ON button at the top left of the 
keyboard is pressed, the display shows the time 
from a 24-hour clock and the date. The 
Organiser’s four main functions are provided by 
the press of a single button. As the instruction 
manual clearly explains, there is no need to type in 
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Rapid File 

The Psion Organiser, 
conceived as a pocket 
computer with a powerful 
database, provides a quick 
and ready filing system. With. 
built-in calculator functions 
and the ability to store and 
retrieve vital information very 
quickly, the Organiser can 
handle some of the functions 


usually restricted to larger 


desktop or hand-held 
microcomputers 
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Handheld Power 

The Psion keyboard contains a 
full alphabet, laid out in 
alphabetical order. This 
arrangement is not intuitive and 
may signal difficulties for 
people accustomed to a 


QWERTY keyboard. The SHIFT 


key provides access to a full 
numeric keypad, calculator 
functions, cursor movement 
and built-in database 
commands 


| HARDWARE/PSION ORGANISER 


commands. These main functions are: 

e SAVE: Data records up to 200 characters long can 
be entered from the keyboard into the display, 
edited with the two cursor controls (left and right) 
and the Delete key, and then SAVEd to either of the 
datapaks. 
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e FIND: This function retrieves data from either 


datapak. A search can be conducted for a string of 
up to 15 characters. The required string is entered 
into the display, and the machine matches this 
against the stored records. The FIND command is 


very fast: a typical time for searching through a — 


database of 21 Kbytes is eight seconds. Records 
containing the required string are displayed in the 
order that they are located. A record can be 
scrolled in either direction using the cursor Keys. 
We used Psion’s Restaurant Guide To London 
datapak, a 16 Kbyte database giving the names of 
105 restaurants, each with an address, telephone 
number, nearest underground station, type of 
food, opening hours, price range indicator, and a 
general comment. A search for the string ‘ARB’ 
gives a match for a restaurant called 
‘BARBARELLAS’ and also a restaurant near ‘MARBLE 
ARCH’ underground station. This function 
compares favourably for speed and convenience 
with many microcomputer database programs. 
e ERASE: This deletes a retrieved record from its 
datapak. There is no ERASE function key on the 
Organiser’s keyboard, and this command can be 
accessed only after the FIND command has been 
used. With the record on the display, the user 
presses the Mode key to obtain the ERASE facility. 
Pressing the Execute button will then erase the 


record from memory. However, this does not free’ 


any storage space for re-use, it merely renders the 
file unavailable to the CPU. We will discuss the 
nature of the datapak memory later in this article. 


e CALC: The Organiser can be used as a four- 


function (add, subtract, multiply, divide) 
calculator using this command. The output can be 


given to seven significant figures, and scientific 
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notation is used for very large or small numbers. computer is needed. It could be used to note 
Once again, there is no key labelled CALC on the experimental results or for keeping an 
Organiser’s keyboard: itis accessed by pressingthe engagements diary, although the keyboard 
Mode key at any time other than after a FIND seriously limits typing speeds because it is set out 


search has been executed. alphabetically. The machine would be best used 

The simplicity and ease of use of the machine is\ for storing information that requires a large 
matched by its low price. The Organiser is amount of cross-referencing — for example, 
commercially viable because low-power  salesmen’s price lists, the indexed contents of a 
technology is low-cost as well. The machine can library, or the names, addresses and telephone 
run on a single nine-volt PP3 battery for up to six numbers of friends. It could also be useful in 
months, because the circuitry uses CMOS applying a computer program to experimental 
(complementary metal oxide semiconductor) data on the spot, or for storing information 
chips and the datapaks are EPROM (erasable intended for further processing elsewhere. 





programmable read-only memory) chips, both of 
which have very low power consumption levels. 
Until recently, the cost of these types of chip would 
Baye made the machine too expensive to have sold 
well. 7 
At the heart of the Organiser is a Hitachi 6301X 
eight-bit processor, running at 0.93 MHz and 


With its conveniently small size, low power 
consumption (there is no need for mains 
adaptors), storage capacities previously only 
possible with desk-bound machines, and effective 
database facilities, the Psion Organiser looks set to 
be a great success amongst people who wish to 
have a microcomputer in their pocket. 





microcomputers. EPROM can be thought of as 


cannot be removed, although it can be accessed as 


chips) and can be formatted up to 100 times. 


have a continuous power source. EPROM chips 


in place of ROM because the chips can be re-used 


controlled by four Kbytes of ROM. There are also 
two Kbytes of RAM for entered data, screen 
information and calculator ‘working space’. 
EPROM datapaks slotted in the bottom of the 
case are the equivalent of RAM memory in other 


‘once-only’ RAM: data written to it is stored and 


if it were normal ROM. Thus it is ‘programmable’ 
ROM. Using the ERASE function of the Organiser 
on a record in the chip does not free its storage 
space in the EPROM, but marks the record to 
indicate to the processor that it is deleted. ‘Thus, 
the datapaks eventually fill up with data until no 
new records can be added. The only way to erase 
the stored data and restore the chip to its original 
‘clean’ state is to expose it to intense ultra-violet 
light. This is the function of the Psion Formatter, 
which costs about £40. New datapak chips cost 
£13 (for eight Kbyte chips) or £20 (16 Kbyte 


The advantage of EPROM over RAM is that it © 
requires no further power to retain data once it has 
been stored, whereas RAM. is ‘volatile’ and must 


are also very reliable, and byte-for-byte cost one 
fifth as much as RAM. They are commonly used 
by computer manufacturers in prototype systems 


and re-programmed in the event of software 
errors, whereas an incorrectly programmed ROM 
must be thrown away. ROM can be used once all 
the faults in the EPROM -held software have been 
found. | : 

Communication with other computer devices is 
possible via an RS232 interface costing £40, 
which fits into one of the datapak slots and allows 
data to be transmitted or received at speeds of up 
to 9,600 baud. The protocols can be programmed 
using the software provided with the interface so 
that, for example, output to a printer can be 
formatted for page lengths and line width. 

The Organiser can be used in a wide variety of 
situations in which a portable and powerful 
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Successful Bid 

The values of the cards in the 
_ bidding are: Ace-4; King-3; 

~ Queen-2; Jack-1. The type in 


red refers to the players’ first bid, 


and the type in blue shows their 
second bid 


WINNING HANDS | 
~ DOWN 


Bridge, like chess, is a game of obsessive 
interest to enthusiasts at all levels of skill. It 
is ideally suited to computer adaptation, 
since it eliminates the need for playing 
_ partners. In this article we look at a program 
that teaches bridge, and programs that aim 
to enhance the skills of experienced players. 








Commercially available bridge programs fall into 
two distinct categories, depending on whether 


they are designed specifically as teaching aids or as 


playing packages. 

There are a number of good tutorial packages 
on the market. Among the best of these, in terms 
of design and presentation, is the Bridgemaster 
series. There are versions of this package available 
for the Spectrum, ZX81, BBC Model B, Electron 


and Commodore 64. This series is designed by. 


Terence Reese, a former world champion, the 
bridge correspondent of the Observer and the 
London Standard, and the author of a number of 
books on bridge. 

The principle behind all bridge tutor programs 
is that the beginner works through a series of pre- 
arranged hands, written into the program. ‘This is 
the essential difference between a tutor and a 
playing package, which generates random hands. 
Because the tutor ‘knows’ what each of the hands 

contains, the program is able to guide the player 

step by step through the many rules and 
conventions that make bridge such an enjoyable 
and intellectually demanding game. 

The Bridgemaster series provides an excellent 
example of what can be achieved by a tutorial 


Inthe bid ‘One No Trumps’, NORTH < 


is telling his partner that he carries at 
least 12 to 14 points in his hand, But 
that he is not particularly strong in 


any one suit 


artner’s hand 





WEST is telling EAST 
that his: hand i iS also 





E 'S Par NerShp lads: WORE Te 
contract | 


——— The bid ‘Two No Trumps’ indicates 
thal SOUTH holds some high cards 
_in-various suits; probably a total of 6 
to 10 points 
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package. There are two programs in the course, 


which are aimed at the complete beginner and the - 


average player respectively. The first is called the 
Complete Learning Package For The Beginner At 
Bridge, the second is Expert Bridge. The 
beginner’s package consists of two program 
cassettes, two commentary tapes, a _ slim 
instruction booklet and Reese’s Begin Bridge, a 
paperback book published by Penguin. This last is 
not meant to be used at the same time as programs 
on the screen. The commentary tapes provide all 
the backup the beginner needs. 

Bridge tutor programs that do not have a tape- 
based commentary have to provide either a very 
comprehensive manual or extensive narrative 
commentary on the screen. Alternatively, they can 
assume at least a basic knowledge of bridge and 
restrict themselves to improving your play. 

For those who do not know the game, the pack 
of cards is first dealt out to the four players who 
pair into teams of two. In computer bridge, the 


standard convention of naming the four players — 


(North, South, East and West) is generally 
adopted. Bidding precedes play, in which the 
players, without showing their hands to each 
other, must declare the strength of their hand of 


cards. The strength of a hand is determined by the 


number of high cards or the number of cards in any 
one suit or both. In our diagram, we show an 
example of bidding. The winning bid will 
determine the contract. This selects what suit is to 
be trumps as well as the number of tricks that the 
winning side must try to make. After bidding, the 


hand is played. In the play, the player that has won - 


the bidding becomes the ‘declarer’ and his partner 
the ‘dummy’. The dummy’s cards are displayed for 
all to see. The declarer will win or lose points 


according to whether he takes the number of tricks 


specified in the contract. 

All bridge tutor programs represent bidding, 
whether or not they allow the player to win it 
properly. In Bridgemaster, the player is given the 
opportunity of making his own bid, having seen 
his cards displayed on the screen. The computer 


- will then declare the bid that is to be made. This 


may differ from the player’s choice of bid. Reese's 


- program, like many tutor programs, is rigged so 


that the computer will accept only the bid or the 
play that the program’s designer wants you to 


make. Reese admits that this leads, on occasion, to. 


a perfectly sensible play by the beginner being 
rejected in favour of the predetermined route that 


has been mapped out. 


Besides displaying your hand and the bidding, 
the program has to deal with the play of the hand. 
The most common method of display isa square in 























the centre of the screen with the four sides labelled 


N, E, S, W. North and South’s hands are then fully [, 


displayed. Usually the four suits are shown: 
spades, hearts, diamonds and clubs, ranked in that 
order, with the card values displayed alongside. 

The player is assumed to be South, and either 
North or South will be the dummy. In either event, 
South always plays the cards for both. In other 
words, South always plays the hand, irrespective 
of whether North or South won the bidding. This 
is, of course, a departure from actual bridge play, 
in which you can spend an entire evening without 
once winning the contract. 3 

In a tutorial program this departure does not 
matter, except in the important area of defensive 
play. These skills are needed when you want to 
stop your opponents from fulfilling the contract 
once they have won the bidding. In a playing 
program, the implications are more serious, and 
we do not know of a playing program that will play 
out a sequence in which East and West win the 
bidding. If you ‘duck out’ of the bidding in, for 
example CP Software’s excellent playing program 
for the 48 Kbyte Spectrum — in other words if you 
deliberately allow East or West to be declarer — 
then the program prints a message on the screen 
telling you that it is not designed to play under 
such circumstances, and instructs you to press the 
R key to generate a new hand. 

When the bidding has been completed, the play 
of the hand is displayed. Depending on who wins 
the trick, either the computer (playing for E and 
W) or the player (for S or N) selects a card. E and 
W’s cards appear on the screen one by one, as they 
would on the table during normal play. 

There are a number of useful features that 
computer-based programs offer. Bridgemaster, 
for example, lets the player choose from four 
options before each deal depending on the level of 
competence. P plays the hands out with the human 
player selecting plays for N and S (under Reese’s 
guidance); A selects ‘autoplay’, where you watch 
the hand played out automatically; H displays all 
four hands on the screen, while D selects a different 
deal. This is a standard set of options with most 
bridge programs. 

The autoplay feature is particularly useful in 
combination with Reese’s commentary, since the 
player does not have to be distracted by the task of 
selecting cards. All deals can be replayed over and 
over again. Playing programs have these features 
as well, but here they act not as repeated drills of 
teaching points, but as post mortems on the 
bidding and the play. 


We have looked at some of the principles of © 


tutorial packages, but there are also a number of 
programs on the market for the more advanced 
player who wishes to improve his game. 


The Expert Bridge package in _ the 


Bridgemaster series that we have discussed. 


previously is a well presented advanced 
instruction course that looks at the complexities of 
such things as high point hands, slam bidding, 
squeeze and blocking plays. 





























oo ba : 

Another package worth looking at for the more 
experienced player is the playing program from 
Alligata Software. Versions are available for the 
Oric, BBC Model B and Electron and the 
Commodore 64. A fair amount of bridge 
knowledge is assumed by the program and there is 
no manual provided with this package, so players 
without good memories had better be prepared to 
take notes. 7 

CP Software’s program for the Spectrum is a 
very enjoyable program to play. It will not play the 
hand as declarer, so there is no way to practise your 
defensive play. However, since most amateurs and 
social players, who make up 98 per cent of the 
world’s bridge playing fraternity, want to play 
every hand anyway, this is not a_ great 
disadvantage. 

Bridge programs, both of the tutorial and 
playing kind, are an ideal way of learning the game 
and improving on your weak points. Bridge is a 
game that demands so many different skills: a 


good memory, analytical skills, the ability to work — 


in a partnership, the ability to play with caution 
and to know when to take a risk, and the ability to 
remain inscrutable and to keep a cool head. The 


games that we have discussed will not perfectly — 


simulate a bridge game between four players, but 
they will certainly give you worthwhile and 
stimulating practice. . 
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Dedicated Challenge 

The two machines pictured are 
bridge-playing computers. The 
first (right) is a table-top game 
called Advanced Bridge 
Challenger, by Fidelity 
Electronics. Bridge Challenger 
is recommended only for 
experienced bridge players as it 
requires a great deal of practice 
and concentration to master. A 
major drawback of the Bridge 
Challenger is its tiny 8-character 
screen. It sells for £169.95. The 
second machine (left) is the 
Systema Play-Bridge computer. 
This operates on batteries and 
costs £29.95. Play-Bridge takes 
only a few minutes to 
understand; it doesn't have 
many advanced features, but it 
is great fun to play 


Pick A Package 

There are a number of bridge 
packages available, ranging 
from teaching programs to 
challenging games that test the 
skills of advanced players. 
Shown here (left to right) are 
Bridgemaster, available on 
cassette for the Spectrum, ZX81, 
BBC Model B, Electron, and 
Commodore 64 at £24.95 each; 


- Bridge from Alligata Software, 


available on cassette for the 
Oric, BBC Model B, Electron and 


> Commodore 64 at £8.95; and 
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Bridge Player from CP Software, 


available on cassette for the 48 
Kbyte Spectrum at £9.95 
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Explosive Play 
The explosion graphics are 
created by generating lines of 
random length within a range of 
--50 to 50 units from the centre. 
The explosion is built up in 
quadrants and mirrored to 


complete the effect 
50 

























































































In the last section of our project to buil 


our Minefield game for the BBC Micros and 


the Electron, we looked at how the program 
detected collisions with the mines. We now 
take the program a step further towards 
completion with a discussion of the 


anirpasieey we will use to create the visual 


. and sound effects of ex ions, 





The BBC Micro and the Electr ort 16 
possible colour variations that we can in 
creating an explosion effect. There are act 

only eight different colours, the other eigh 
variations being flashing effects between one 
colour and another. Normally, the flashing 
combinations of colours alternate every half a 
second, but the flash rate can bec two FX 


- commands. *FX9 sets the amount of tim 


first colour of the flashing pair is displayed. The 
« ume is measured in units of fiftieths of a second. 


” Thus, *FX9,20 alters the display time of the first 


ealeue to 2/5ths of a second. The 


command, *FX10, can be used to alter the display 


time of the second colour in the same way. By 
altering one or both display times, interestin 
flickering effects can be produced. 

The visual explosion effect can be produced by 
drawing a series of short lines in various colours 
out from a central point. To enhance the effect, the 
colour of the mines and score lettering 
rapidly changed. As these w riginally 
PRINTed in logical colour 2 (which we set to green) 
we can use the following command to reassign 
logical colour 2 to a colour randomly selected 
from the 16 possible combinations: 


VDU19,2,RND(15),0,0,0 _. 


[to 15. This 
, but as colour 
lour, this does not 


























































































































RND(15) selects a whole number 
means that colour 0 is never s 
0 is black, the backgroun 
matter. 

The colour used to plot the explosion fiers can 
also be randomly selected using GCOL 0,RND(3). 


We then use a loop to draw a series of lines from 


the centre of the explosion in a series of randomly 
selected colours. Up to now we have looked at the 
high resolution commands MOVE and DRA 
DRAW (X,Y) always draws a line to the point wi 
‘absolute’ co-ordinates (X,Y). However, » 1S 
another family of high resolution wing 
commands that allow us to, among r things, 
specify points ‘relative to’ one another. The PLOT 
K,X,Y command can be used to 
relative or absolute points dep 
of K. The following tab 











ing on the value 
ows some of the 
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explosion centre), 


es between 



























































































































































































































































PLOT4 and PLOT5 are entirely’ equivalent to 
OVE and DRAW commands. ur osion 
t we $ PLOT1 to dra relative to 
the f losion. > we,can dra 
any lines, : >ed to ere / 
centre of the 
In the last section se, whe : 
a dummy f PR d@s.we passec 
of xgraph and” OXplode. and 
explode. no Patti 
procedure but will n se 
e explosion. If this 
‘om line 
xgraph and ygraph will be the graphi 
of the ce : contain 
s, MOVEx-explode,y-e | 
graphics cursor to the 
the ex oY 
another pair IDLES Or USE 
ithin the e yn p instead 
using xgraph an , 1s.that this p 
also be call a ‘part 
where the co-ordinates of t e explosi nt 
b ied different pair of vari .B 
g pafdineters into the explosi6n p : 
we have made it more le. iF 
Once we have M Viele of 
explosion, we sh aw ne 1 ran 
direction to, say, a maximum of 50. units: 
PLOT 1,RND(50),RND 
will not quite do the job, as it will not 
negative co-ordi . (A ne e X CO- a 
produces a line. 1 to the left, while a i 
rdinate / a line ¢ down from the 
Xplosion centre). Repeated use of this d 
will fill ne quarter of the space e 
— centre @where both co-ordinates are positiv 
as t we can introduce negative,yalues (and 
he raw lines in all directions”around the 






































ust replace RND(50) with 














RND(100)-50. Th imum value of RND(100) is, | 
of course, 100, so the most that RND(100)-50 can 
be is 100—50 = 50. The minimum value of 


RND(100), on other hand, is one. Hence, 
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RND(100) can be as small as 1-50 = -49. 
By repeatedly MOVEing to the centre of the 


explosion and then drawing 


units in any direction and c , we can produce a 


tive line up to 50 © 





SSSODEF PROCexplodetx explode,y explode) 

SOS6OREM. ** SOUNZ FECT..2* 

SS POSO0UhoG oc aoe, SO 

SoOS0REM ## be “LAS A RATE ee 

Sor Ur Ho, 20 

SSO SFX 10 | 30 

Sé410F0F [=1 To 100 

342010! xplode,y explade 

2430 §19,2,RNDC15), Cte gl 

es aC OL O,RMD¢ 33 ; 

2520 ‘LOT = RAO Ci Stl. ,RNDX 100)-50 
SSOMEXT | 

fet re age 

S480 EN DPROC 

THE ‘RESET’ PROCEDURE 


After an explosion there are several tasks to do: 
® We must reduce the number of lives remaining 
and check to see if all the lives have been used. 




















@® We must c he mess made on the screen 
by the ex 
@ t reposition the detector and assistant in 


arting position. 



































visually exciting effect. 

Now let’s consider ho can produce $6und 
effect company the explosive gr on 
screen possible to create quite so icated 
sou ing BBC ’s SOUND ENVELOPE 
co s. SOUND can generate r pitched 
notes (0 you can play a tune) or ‘ndise’ for speci 

SO ects. T VELOPE and is u 
co ion with SOUND to ‘shape’ the sound you 
hear, and th ulate muf§i¢al inst S. 
ND has four nymbers (or parameters) 
ted it, whi ntrolt aracteristics 
> to oduced. ‘These a follows: 
OUND C,A,P,D 
is the cha nu , which must be a value 
t 0 and 3°C els 1 to 3 produce pitch 
ut chan is for special sour 
is that we: e 
iS ude, o the volume 
uced me is set when 
nd 6s.to silence when A is zero. 
al sed t the shape 
soUnGg 4 a. togel 
e note — in other words 
the sound is. | 
that the tone 
alues of D from 0 to 254 cause the 
Uifits of 1/20th__ 
, to hold a note for : 
nty. If D has the 
til you 
X ff early needs t 
um S our command 
| ignified by a 
va O e pitc 1S more 
co en used wit el 0; es 
lues fro rding to les 
of fo Ise wave S produc 
pe sou wherea noise 
wavefo produce ounds like a television 
set before ihas been correctly tuned. ThessOUND 
co nd We will use in our program is: | 

SOUND 0,-15,4,40 
which produces a high pitched hiss, ee two 
seconds (40/20) with the vol t to maximum. 
Here is the complete listing for the procedure: 



























he first of these is easily accomplished by use 

of a count that\is incremented each time the 
procedure is called. If the count exceeds four after 
incrementation then a special variable, end flag, is 
set to o al the fact that the game is over. 
for the end of game, we have to 

r up the explosion. Several methods could be 
employed here, such as PRINTing blank spaces 
over the area of the explosion. However, the 
method we use is to clear the screen, relay the 
nd reprint the time and scores information. 


To make it slightly fairer, we should relay only the 


same number of mines as were left before the 
ion. This can be easily calculated from the 

s each mine is worth 150 points and there 

were 50 originally, we can calculate the number of 
mines left and pass it to the ‘lay mines’ procedure. 
he mine detector and assistant are 

re re-initialising their co-ordinates 
(by calli initialise variables procedure), and 


then calling the position chars procedure. The full 


Reset listing is shown below. Add this and the 
explode procedure to your program. 

SHDEF PROCreset 

— nt=count+I 
PPO mt?4 THEN end flag=1:ENDPROC 


a Cire 





tt tt Oa ta 


27 LCL 

SPeUMDUL? 252, ,0,0 
2°30 COLOUR 2 
SP40ORPROCinitialise variables 
sF30mines _left=50-Score/150 
S7S0PROCTay minestmines leftd 
S27 FORPROC rs ala border 
S9SOPRINTTABC2, 273 ¢"Time" 


SP POPRINTTABCZ, 283 "Score" 
S000PRINTTABC 11,25) scores 
A010PRINTTABCZ,299"Hi score" 
OZOPRINTTABCI11,29°hi_ score 


ASM We menS=LEFT#(ment,4-count> 


RINTTAB(2, 30) ;remaining_meng;' : 
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DIGITAL PLOTTERS 


Plotters used by home computer owners are, 
almost invariably, digital in design. They are 
connected to the micro via the printer interface 
and are used to interpret bytes of data in such a way 


as to produce (x,y) co-ordinates, andinsome cases | 


different colours, as printed output. Earlier 
plotting devices were analogue in nature, and 
these were widely used in scientific applications. 
_ Forexample, ananalogue plotter would be used to 


show how the temperature ofa furnace varied over JPRS 


a given period of time. 


DIGITISE | 

To digitiseis to convert analogue information into 
its digital equivalent. One application is the 
digitising of speech: the output of a microphone is 
fed into an analogue-to-digital converter, and the 
resulting bytes of data are stored on disk. By 
reversing the process, the computer can reproduce 
speech in a far more intelligible form than a speech 
synthesiser can. However, in such applications, the 
term ‘sampling’ is more common than ‘digitising’, 
because the signal is being sampled and measured 
at regular intervals. It can be _ proven 


mathematically that to reproduce a signal 


accurately it must be sampled at least twice as often 
as the highest frequency in the signal. Thus, if we 


assume that speech entails frequencies from 


300Hz (hertz—cycles per second) to 3,400Hz, the 
signal must be sampled 6,800 times per second. 


_DIGITISER 


Many applications for computers, notably in the 
fields of engineering, surveying and design, 
require that a visual image on paper be transferred 
to the computer. The device needed for this is a 
digitiser. The most advanced units are essentially 
television cameras coupled to very fast A-D 
converters (see page 28), but, more commonly, the 
image has to be traced over by hand, using a 
special stylus. 

The means by which the digitiser detects the 
position of the stylus, and thereby creates the 
digital values to represent the image, varies 
considerably. Some units employ a mesh of wires 
embedded in the base plate of the unit. In this 
system, the stylus traced over the image picks up 
the magnetic field from the wires. Ultrasonic 
systems exist, too, in which two sound detectors 
measure the distance from the pen, and calculate 
its absolute position. 


DIL 

To reduce matubseh ning costs, most integrated 
circuits (chips) are soldered directly onto the 
printed circuit board. They are inserted into the 


holes on the board using automatic insertion — 


machines, and then the whole assembly is dipped 
into a bath of molten solder. 

On older microcomputers, the chips weren't 
soldered to the board but were inserted into DIL 
(Dual In-Line) sockets that were soldered onto the 
board. The DIL name simply comes from the two 











The photograph above is a printed circuit board froma home 

computer showing a DIL socket 

lines of pins that characterise integrated circuits. 
Despite the increased manufacturing costs, the 

advantage of using DIL sockets is that the 


replacement of faulty chips doesn’t entail any 


soldering. However, RAM chips are now far more 
reliable than they were 10 years ago — and, faced 
with a fault, many manufacturers now find it 
cheaper to replace the whole board than to de- 
solder an individual chip. 

Some home computers feature empty DIL 
sockets on their printed circuit boards. These are 
particularly useful, as they allow additional ROMs 
(for a disk operating system or graphics utility 
language, for example) to be fitted by the user. 


DIMENSION 


The number of dimensions in a system is the 
number of parameters that must be supplied to 


specify a unique point in that system. We are used 


to three-dimensional spatial systems, where co- 
ordinates on three axes define a point in space. 
In computing, the concept of dimensions 
becomes relevant when we deal with array 
variables. The array A(5,6) is two-dimensional, 
because two quantities have to be given to access 


any particular variable element. Note that the size . 


of the array is something quite different: in this 
case it is 30 (5S X 6) elements. Some Basics will 
allow only one or two-dimensional arrays. 


| DIRECT ACCESS 


This is really a better term for random access — 
particularly when referring to disk files. Direct 
access means that any item within a file can be 
accessed immediately, without the need to work 
through a lot of other items — as is the case with a 
sequential access file. If a file is composed of 
records — as in a database, for example — this 
means that the disk operating system must keep a 
constantly updated set of pointers to indicate 
where each record starts within a file. When a 
particular record is requested from disk, the DOS 
looks up its position from this table, and then 
moves the head directly to the appropriate track 
and sector. | 
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ALA Hectan was 


developed to provide some of the features 
offered by the BBC Micro at a lower price. 
However, the machine lacks many facilities 
required by the home user. The new 
Electron Plus 1 interface, priced at £60, can 
transform a standard Electron machine into 
a low-cost alternative to the BBC Micro. 





| The Bleciae was coriccived as a Seale: déwa 


version of the BBC Micro. Its designers retained 
the excellent BBC sasic and operating system, but 
dispensed with most of the interfaces that make 
the BBC Micro so versatile. In fact, the Electron’s 
only connections are a cassette port, two monitor 
sockets (RGB or composite video), a modulator 


- output for connection to a television, and a power 


socket. 

The Plus 1 interface adds to the standard 
machine a parallel printer ‘port, a joystick socket 
and two sockets for plug-in ROM cartridges. 
Acorn hopes that the extra facilities will increase 
sales potential. The cartridge slots and joystick 
port allow the Electron to be used for arcade-style 


_ games, while the printer port is a useful feature for 


the user who needs to be able to print out program 
listings, or who wishes to use word. processing 
software. — | | 

Installation of the Plus 1 expansion unit is very 
easy: it simply pushes onto the edge connector 
that protrudes from the rear of the Electron. Two 
bolts are then pushed through the Plus 1 casing 
and attached to the threaded sockets in the 
Electron casing. All power and data are 
transferred via the edge connector. The extra 
software needed to ‘drive’ the new interface is held 
in a ROM chip inside the unit. 


The printer port is a standard Centronics’ 


parallel type. To enable the printer, the user must 
type the command VDU2, and to disable it, VDU3 
must be entered. These commands are identical to 
those used on the BBC Micro. Similarly, VDU1 is 
used to send a character to the printer; again this is 
standard BBC Basic. 

Joysticks are plugged into the analogue port. 
This is a 15-pin D-type socket, and pin 
connections are identical to those on the BBC 
Micro’s analogue port, allowing any BBC- 
compatible joystick to be used. The Plus 1 can 
measure up to four analogue voltages, either from 
four games paddles or from two joysticks (each 
joystick produces two voltages: one for up/down 
movement, the other for left and right). 

The process of converting analogue voltages 
into digital signals that can be handled by the 


originally | 


computer is performed by an analogue-to-digital 


converter chip — in this case, an ADC0844. This 
is a less complex chip than the one used in the BBC 
Micro, which means that the Electron does not 
follow the movement of a joystick as accurately as 
a BBC machine does. In games programs, where 
the joystick is used simply as a four-way switch, 
this is not a problem. If the joystick is used with a 
graphics program — to draw ‘freehand’ on the 
screen, for example — movement is noticeably 
jerky on the Electron and the resulting picture is 
less detailed. 

When the Electron Plus 1 is first switched on, 
the cartridge in the front ROM socket starts 
running automatically — to stop it, Escape must 
be pressed. The ROM filing system works very 
much like the cassette version (it’s much faster, 
though), so commands like *CAT, LOAD and CHAIN 
are understood. To use cassette software with the 
new unit, you must enter the command *TAPE or 
remove the cartridge, remembering to switch the 
power off first. In addition to games programs, 


_ other languages will also be produced in cartridge 


form. Unlike the games ROMS, these language 
ROMS are ‘switched in’ to replace the usual BAsIc 
ROM. 

The problem with most computer add-ons is 
that they often have unwanted side-effects. When 
the Plus 1 unit is connected to the Electron, 
loading errors may result when cassette programs 
are used. This is especially true for programs that 
contain data files — we found that two of the 
programs on the Electron’s introductory cassette 








Room For Expansion = 

The Electron was originally 
conceived as a cut-down 
version of the BBC Micro. It 
lacks almost all of the BBC’s © 
many interfaces, yet still offers 
the same excellent graphics and 
BASIC at half the price. Now 
Acorn has produced a unit 
known as the Plus 1, which 
gives the Electron the most 
important interfaces for £60 
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‘would not load on the expanded Electron. By 
using a series of operating system commands, 
however, you can ‘fool’ the Electron into thinking 
that the Plus 1 is not connected and so restore 
normal performance. This is barely mentioned in 
the manual and could prove confusing to the 
novice user. | ea 

Onany Acorn machine, typing *HELP givesa list 
of the various ROMs inside the computer. Typing 
this on the Electron with the Plus 1 unit fitted tells 
you that the main operating system ROM is 05 
1.00, and also lists Expansion 1.00 ADC/Printer/RS423. 
This is the operating system ROM inside the Plus 1 
expansion unit, but the interesting thing about this 
is the last piece of information — RS$423. This is a 
reference to a standard serial interface, yet neither 
the Electron nor the Plus 1 supports such a facility. 


Acorn is, in fact, planning to introduce a serial 


interface at a later date. 
The major difference in the two Basics is that the 
Electron lacks Mode 7, the teletext-compatible 


- graphics mode. This mode is used for titles and 


instruction pages in BBC Micro programs as it is 
economical in terms of memory. On the Electron, 
the various viewdata attributes do not turn on the 
Mode 7 colours and flashing letters, but are 
instead displayed on the screen as gibberish. Most 
games programs use a different mode for the 


actual play, so there’s no problem once the title 
_ page and instructions have been bypassed. 


The other major difference between the two 
machines is in the SOUND and ENVELOPE 
commands. The Electron has a solitary sound 
channel, instead of the four offered by the BBC 
machine. Similarly, the Electron ENVELOPE 
command affects the pitch only, and not the 
volume. The commands are compatible, though, 
so a program that uses them will work on both 





machines — although the sound will be noticeably 


different on the Electron. | 
The Electron keyboard has a better ‘feel’ than 


that of the BBC Micro, but it has fewer keys. ‘This 
means that on the Electron, as on the Sinclair 


- Spectrum, most keys have three or four different 


functions. For example, the key marked ‘L’ will 
produce either ‘l’ or ‘L’, depending on whether the 
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Shift key has been pressed; but if used in 
conjunction with the Function key the ‘L’ key will 
generate the BAsiIc command LIST. Pressing the 
Control key at the same time as ‘L’ will clear the 
screen. It would perhaps have been better if Acorn 
had retained the 10 red Function Keys provided on 
the BBC Micro, as these can be programmed to 
perform various useful tasks. The Electron does 
have Function keys, but these are merely the 
numeric keys pressed in conjunction with the 
Function key. | | 

The one area in which the two machines differ 
dramatically is in the range of interfaces provided. 
The BBC Micro has more interfaces than any 
other home computer, which means that a host of 
peripherals — from printers, modems and disk 
drives to second processors and robot arms — may 
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easily be attached. All of these require additional 
chips and sockets, which inevitably add to 
production costs. By omitting these interfaces, not 
only are the extra chips unnecessary but power 





requirements are less and the computer is smaller 


and cheaper. That was the philosophy behind the 
original Electron. The fact that Acorn has now 
introduced the Plus 1 suggests that possibly this 
cost-cutting went too far. | | 

The Electron Plus 1 is less versatile than the 
BBC Micro and offers fewer expansion 
possibilities. But many users do not require such 


facilities and at a price considerably less than the 


BBC machine, the Electron Plus 1, with its 
excellent graphics and sound facilities, structured 
BASIC and a growing range of software, looks good 
value for money. | 
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Our programming projects series ; continues 
with a look at a program that allows us to 
_ draw three-dimensional shapes and rotate 
them. The geometrical principles used in 
the program to plot the points on the 
outlines provide a basis on which simple 
animated graphics can be developed. 


The program we provide uses some basic 
geometric principles to create perspective 


angle or distance. All the data for the objects are 
stored in DATA statements in the program. These 
comprise three-dimensional co-ordinates for each 
end point of a line in the object. For each point 
there is also a figure to indicate whether it is at the 
eginning of a line or at its end, which tells us 
y+hether the line is to be drawn from, or to, that 


To turn these three-dimensional co-ordinates 
into two-dimensional values representing points 
on the screen is a matter of simple, but lengthy, 
mathematics. The x and y co-ordinates of each 
point (in the plane of the television screen) are 
_ divided by a factor representing the distance of the 
object from us. In addition, the resulting co- 
ordinate is scaled by a factor suitable for the co- 
ordinate system of the micro. By changing the 
distance factor, the object can be made to shrink or 
grow as it approaches or recedes from the viewer. 
A third constant can be used to change the 
effect of the perspective projection. By increasing 

the value of this constant the perspective view of 
_the object is exaggerated, as though it were being 
viewed with a wide angle lens. Decreasing this 
constant gives the effect of flattening the view, as 
though we were looking through a telephoto lens. 
In addition to creating a perspective view of the 
object, the program also allows it to be rotated so 
that it can be viewed from any angle. This is done 
by simple trigonometry. The axes are rotated 
through the desired angle so that when the 
perspective projection is made the image on the 
Screen appears to have been rotated. This can be 
done either as a rotation around the y axis (the 
viewpoint appears to move around the object) or 
around the x axis (the viewpoint rises above or 
below the object). 


Although our program can create all of these 
effects, it is remarkably simple in operation. 
Control of the viewpoint is through number keys 
one to eight. These will give, respectively: a 
movement of'the viewpoint to the left, the right, 
up, down, towards the object or away from it; an 
increase in the perspective effect (fisheye); or a 
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projections of objects that can be viewed from any - 


























UBIST REVOLUTION 


decrease in the perspective effect (telephoto). 
The current three-dimensional co-ordinates are 
stored as three arrays: X, Y, and Z. The changes to 
these arrays and the changes to the constants used 
in the perspective transformation are made in a 
series of subroutines. Each time a keypress is 


detected, the image on the screen is erased by 
- drawing it in the background colour, the desired 


change is made with a call to the right subroutine, 
and the new image is drawn again. 

The perspective transformation is made in the 
subroutine that draws the image. This goes 
through each set of threé-dimensional co- 
ordinates, translates them to two-dimensional co- 
ordinates and plots them on the screen (either 
moving to the points or drawing lines according to 
the fourth piece of data for each point). 

Creating your own object data for this program 
is a fairly lengthy business, but very 
straightforward. The data is stored in statements at. 
the end of the program, with four values for each 


- point in the object. The total number of points is 


set in the first line of the program. This should be 
changed to suit your data. The data we give creates 
a cube with a diagonal line across one face. 

Each set of four values is in the order: plot or 
draw value, x co-ordinate, y co-ordinate, z co- 
ordinate. The values are calculated by mentally 
tracing the outline of the object in three 
dimensions. Using an imaginary pen, visit each 
corner point of the object’s outline in turn. If your 
pen is moved to a point without drawing a line, 4 is 
used for the first value. A value of 5 indicates that a 
line is to be drawn to the point from the preceding 
one. These particular values are used because they 
make the program for the BBC Micro less 
complicated. 

The co-ordinate origin (0,0) is at the centre of 
the screen. It is best to make this the centre of your 
object. The x axis is the horizontal axis, with 
positive values going upwards. The z axis is the axis 
in and out of the screen. The positive direction on 
this axis is into the screen. 


Keep the X, Y, and Z values as small as is 
reasonably possible. The initial setting of the 
perspective effect and viewpoint distance must 
take into account that an object width of about 10 
will fill the screen. This could be changed by 
altering the scaling factor used in the perspective 
transformation. We suggest that you experiment 
with simple shapes first. Keep the number of 
points low. When you have mastered the digitising 
of simple solid objects (a pyramid, a cube) you can - 


-move on to more complex ones. 


Our program could be extended further to give 


_additional effects. A translation facility could be 











THREE- DIMENSIONAL GRAPHICS/ PROGRAMMING PROJECTS 


e©o00000 00 





incorporated to move the object, without rotation, 
relative to the co-ordinate origin. You could 
attempt to incorporate a routine to remove the 
lines and parts of lines that should be hidden from 
view. This makes the present wire frame image 
much more realistic. However, such hidden line 


Spectrum Version ‘BBC Version 


19 LET N=16 1@ N=16 
2@ DIM P(5@) | 2@ DIM PCS5e@>,X<50) ,¥(50) ,2(50) ,A(50) ,B(50) 
21 DIM X(50) $0 MODE@:VDU29,640;512;5 
22 DIM Y(59) D=10:P=0.5 
23 DIM Z(5®) SI=SIN(9-99) :CO=COS(0.09) 
24 DIM A(5@) FOR I-1 TO N 
25 DIM B(5@) : READ P(1),X¢1),YC1),Z<1) 
d® LET D=1@: LET P=0-5 NEXT I 
5@ LET SI=SIN 9-99: LET CO=COS 9.09 : 
60 FOR I=1 TO N GCOL®,3:GOSUB 300 
‘ 7@ READ P(I),X¢(1),YC1),Z(1) IS=GETS$ 
8 NEXT I V=VAL(1$) 
90: : 230 GCOL@,@:GOSUB 300 
200 INVERSE 0: GO SUB 300 24 ON V GOSUB 1000,2000,3000,4000,5000,6000 
210 IF INKEYS<>"" THEN GO TO 210 ,7090,8000 ELSE 1590 


removal is a vastly complicated matter. It requires fi 
very complex mathematics and would slow the _ 
program down a great deal. Even if you never add 

to this program but leave it exactly as it is given 

here, you can still achieve some pretty spectacular, 

or just pretty, results. 


ay 
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ar 


211 IF INKEY$="" THEN GO TO 211 


212 LET I$S=INKEY$ 
GO SUB 300 


230 INVERSE 1: 


240 IF 
241 IF 
242 IF 
243 IF 
24d IF 
245 IF 
246 IF 
247 IF 
2580 GO 


T$="1" 
I$="2" 
I$="3" 
T$="q" 
T$="5" 


L$="6". 


I$="7" 
I$="g" 
TO 200 


THEN 
THEN 
THEN 
THEN 
THEN 
THEN 
THEN 
THEN 


SUB 
SUB 
SUB 
SUB 
SUB 
SUB 
SUB 


SUB 


1600 
29000 
3900 
4060 
3900 
6900 
7000 
3000 


290 GOTO 200 

260 : 

5S@6O FOR I[=1TON 

310 ACI )=XC1)#1@@0/ CP¥ZC1)+D): BCI)=¥C1)* 
1000/(P*Z(1)+D) 

oe NEXT I 

oo@ FOR I=1 TO N 

5d0 PLOT Pc1I),ACI),BCI)D 

S00 NEXT I 

RETURN 


FOR I=1 TO N 


260: 
3@@ FOR I=1 TON 
310 LET ACI)=XC1)*300/(P#ZCI)+D): LET BCI)=YC 
1)*#300/ (P¥ZC1I)+D) 

320 NEXT I 
330 FOR I=1 TO N 
3d@ IF PCI)=4 THEN PLOT ACI)+128,BC(1)+85 
345 IF PCI)=5 THEN DRAW ACI)-ACI-1),B¢1)-BCI 
—1) 
35@ NEXT I 
36@ RETURN 
370: 
19@@ FOR I=i1 TO N 
191@ LET X=XCI)*CO-—Z(1)#SI 
1920 LET Z=Z(1)*CO+X(1I)*SI 
19@3@ LET XCI)=X! LET ZC(1I)=Z 
1@4@ NEXT I : 
1950 RETURN 
19690: 
200@ FOR I=1 TON 
2010 LET X=XC1I)*#CO+Z(1I)*SI1 
2020 LET Z=ZC1)*CO-X(1)#SI 
2030 LET X¢(I)=X! LET ZC1I)=Z 
2@4@ NEXT I 
2050 RETURN 
2060: 
3@0@ FOR I=1 TO N 
3010 LET Y=VYCI)*CO+Z(1)*SI 
3920 LET Z=ZC(1)*CO-YC(I)#*SI 
3@3@ LET YCI)=Y¥!: LET Z¢(1)=Z 
3@d@ NEXT I 
3050 RETURN 
3060: 
400 FOR I=i TO N 
4010 LET Y=YCI)*CO-Z(1I)#SI 
4020 LET Z=Z(1)*CO+Y(I)*SI1 
4630 LET YCI)=Y¥: LET Z¢1)=2Z 
4@4@ NEXT I 
4050 RETURN 
4960: 
5@0@ LET D=D#0.9 
5010 RETURN 
5020: 
6000 LET D=D/90.9 
6010 RETURN 
60205 
7900 LET P=P/0.9 
7010 RETURN 
7920: 
8000 LET P=Px*0.9 
“801 RETURN 
8020: 
9000 DATA 4,1,1,1, 5,1,1,-1, 5,-1,1,-1, 5,-1,1 

1, S,1,1,1 

9010 DATA S.1.-1.1. 53.1.-1.-!. 3,-1.-1,-1, 5,- 

1,-1 i, S.t.-i 
9020 DATA 4,1,-1,-1, 5,1, oe 5 
1.4.) 

9030 DATA 4,-1,1,1, 5, 


| 


»—1,-1,-1, 3y- 


eit 


X=XC I )*CO-ZC1)*#SI 
Z=ZC I) *CO+X CI) *SI 
XCI)=X2Z¢C1I)=Z 
NEXT I 

RETURN 


FOR I=1 [ON 
X=X CI) *¥CO+Z¢C1)*S1 
Z=Z¢(1)>*CO-X¢(1I)*S1 
XC ID=XEZC1)=Z 
NEXT [| 

RETURN 


FOR I=1 10 N 
Y=YCI)*COtZ(I)D*#SI 
Z=Z(1)*CO-YCI)*SI 
YC ID=Y°Z¢1I)=Z 
NEXT I 

RETURN 


FOR I=1 TO N 
‘Y=YC1)#CO-Z(1)*S1 
Z=Z2(1)*CO+YC(1)#S1 
Y¥(1)=YViZ(1)=Z 
_NEXT I 

RETURN 


D=D#.9 
RETURN 


D=D/-.9 
RETURN 


P=P/.9. 
RETURN 


P=P*.9 
RETURN 


DATA 4,1.1,1, 3,1,1,- 
10010 ‘DATA 5,1,-1,1, 5,1,-1 
'=t.-1... 3,t.71,1 

19020 "DATA d,1,°1,-1, 35.1.1 

=1,1,-1 
100390 DATA GO, -t.iit, ee Ee 





| 2,7 asig7 
7-1, 5,°1 
sl, ae 
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IECES OF THE PUZZLE 





The most efficient way to create programs in 
any language is to use ‘modular structuring’. 
Some languages, such as PASCAL, encourage 
this approach, while Basic users need to 
discipline themselves to adopt the 
technique. We show you how your 
programming will be greatly enhanced using 
modules of code as your basic components. 





A module is a piece of code that performs a 
particular function. The points of entry and exit, 


known as the module’s ‘interfaces’, must be 
precisely defined, and the processes that occur 
between these interfaces should be entirely 
independent of the rest of the program. Once a 
module has been written, it can be treated as a 
‘black box’. Data may pass in and out of the 
module's interfaces, but what goes on inside can be 
left to itself. 

Modules can be joined together to build up a 
program without the writer having to worry about 


how they perform their tasks. A stock of modules 


can be built up by a programmer to be used when 
needed, and programmers can pass modules on to 
be used in another writer’s programs. But in order 
to take advantage of modular structured 
_ programming, we need to take careful note of the 
flow of control and the flow of data when we write 
the modules. 

To ensure that all your modules behave in the 
same way with respect to the flow of control, a very 
simple rule should be followed: all modules 
should have a single entry point and a single exit. 
What this means in practice is that the flow of 
control within the module has to be carefully 
designed so that it starts at one place and, no 
matter how much it loops and branches, it reaches 
the same exit by all possible routes. 

Modules correspond to the algorithms we have 
been looking at in previous instalments of the 
course. ‘Structured’ languages, such as PASCAL, 


allow the programmer to create subroutines that — 


may be called by name, and which use their own 
variables. Such languages encourage a 
programmer to enter or leave a routine (called a 
‘procedure’ ) by single entry and exit points. 

In Basic, using the GOSUB .. . RETURN 
combination, a subroutine can be called from the 
main program and, after the subroutine has been 
carried out, control will return to the line 
immediately after the GOSUB command. However, 
there is no restriction on which line the GOSUB 
sends control to. Two different GOSUBs may send 
control to different lines of a subroutine with a 


single RETURN, and the result might be completely © 
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different in each case. Similarly, there is no 
restriction on how many RETURN statements ae 
be used in a subroutine. 

This means that the BAsic programmer must be 
self-disciplined. You should start by making sure 
that all GOSUBs to the same subroutine point to the 
same line number, and that every subroutine has" 
only one RETURN init. It is best to get in the habit of 
marking the first line of each subroutine with a 
REM statement giving it a title, and use that line as 
the entry point. Make the RETURN the last line of 
the subroutine. This is not essential but it makes 


‘things much clearer. 


THE GOTO RULE 

Extra care should be taken with the GOTO 
command, which can play havoc with program 
structure. The rule here is: only use a GOTO to send 
control to a line within the same subroutine. ‘This 
avoids the potential danger of skipping over a 
RETURN or passing control to the wrong RETURN. 
There are times when it is necessary to leave a 
routine without executing every line. In this case 
you should GOTO the line with RETURN on it, and 
there should be no problems. 

Using GOTO within loops is even more 
dangerous. If control jumps out of a loop, BASIC 
cannot know this and assumes that the rest of the 
program is the body of that loop! The safety rule is: 
when in the body of a loop, never GOTO a line 
outside the body of that loop. If a loop needs to be 
terminated early, set the loop counter or test 
variable to the terminal value and GOTO the test line 
(the line with NEXT or WHILE in it). As with the 
RETURN statement, put NEXT or WHILE on a line of 
its own to make this easier. Keeping track of the 
structure of a program is a lot simpler if GOTOs are 
avoided as much as possible. 

Branches are the most likely place for control to 
go astray, so try not to allow any decisions to send 
control out of a subroutine unless it is with a proper 
call to another subroutine. Remember that each 
subroutine has a single exit point, so make sure 
that it is possible to follow the flow of control 
through every branch to that point. Drawing a flow 
chart for the routine makes this easy to check. 
Setting a flag can often reduce the need for GOTOs 
in routines involving loops and branches. 

We can think of data passing in and out of 
modules, just as we did for algorithms (see page 
386). So that modules can be used independently 
of each other, you must design them so that the 
only influence they have on each other is through 
the data that passes between them. The main 
program passes data to a module and, when the 
module has been executed, any result that has 











/ 


been generated is passed back. 


Data moves around programs inside variables 
and the freedom of movement of a variable is 


called its ‘scope. Many programming languages 
can restrict the scope of a variable to particular 
subroutines. In PASCAL, the variables used in a 
particular subroutine (procedure) must be 
‘declared’ for that procedure. Variables declared 
for the main program are globaland may be used 
anywhere in the program (including within any of 
its. modules). Variables declared within a 
particular procedure, however, are Jocal to that 
procedure and can only be used there. 
Local variables can have the same names as 
global ones and using one does not affect the value 
of the other. Using a language that supports local 
variables allows us to write subroutines without 
having to worry about how the variables used in 
the routine might affect variables in other 
routines. Unfortunately, very few versions of 'the 
BASIC language support local variables, which 
means that if we wish to write independent 
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subroutines we must somehow simulate the effect 
of having local variables. 

The simplest way to do this is to adopt naming 
conventions that: distinguish variables that do 


different jobs. Some conventions already exist and 
are widely used by programmers. Using |, J and K 


as loop counters and index values is very common, 
a practice that has been adopted from 
mathematics. | 

Having described a program with a flowchart, it 
is a simple matter to number the subroutines 
involved, or to give them some other kind of code. 
Any global variables that need to be made local to 
a particular subroutine can then be suffixed by this 
code to make them unique. Thus, routine number 
5 may use the local variables SUM5 and TOTALS to 
distinguish them from SUM12 and TOTAL12 in 
routine number 12. Be careful though that the 
BASIC you are using doesn’t look only at the first 
two characters! Variables that are used to pass 
values between subroutines and those used only in 
the main program need not be coded. } 
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Day For Night 


Valhalla i isone of several games 
produced recently whose 
graphics indicate the passage of 
time by darkening the screen. 
This creates the effect of ‘day’ 
and ‘night’ 


PLAYING WITH THE 
GODS ~ 





Valhalla is i “ an adventure game We flavoured 
with references to Nordic mythology. 


Written for the Spectrum and Commodore 


64, it has proved hugely successful, 
capturing the public’s imagination through 
its innovative programming and spectacular 
graphics. It has won for Legend, its 
manuf icturers, several software awards. 


Ther are 81 idenhone: in the Valhalla Naiveanies: of 
which 16 are in Asgard — including the elusive 





Valhalla, the place of your dreams. Midgard 


consists of 20 locations, and the remaining 45 
collectively make up Hell. There are eight exits 
from each location, although some of these may be 
blocked or require you to have possession of a 
magic object to let you pass. ‘To make things more 
complex, there are ‘ringways’ connecting distant 
locations; if you are wearing a suitable ring you can 
‘jump’ to the far-off scene. 

Valhalla has a cast of 36 characters (at least 
three will be on the screen at any one time), who 
are either good or bad. They interact continually, 
having fights, giving each other food or wine or 
throwing objects at someone they dislike. 

You can interact with them at any point, 
entering the actions you wish to perform via the 
keyboard. On the other hand, it is possible for you 
to sit back and watch the fun, though the silent 
observer types will invariably end up dead. 

The game does not present a single path of 
action to success; the player can take many 
possible routes. You have to convince the good 
characters that you are worthy of being helped by 
them. So, if you are feeling in a dark mood, you 
could just as easily decide to spend your energy 
being thoroughly nasty and get the support of the 
bad guys. 
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The graphic displays of Valhalla are particularly 
good, especially on the Commodore version. A 
background for each location is first drawn on 
screen, in vivid primary colours on the Spectrum 
and subtle pastel hues on the Commodore. Next 
the characters appear: on the Spectrum, these are 
rather stick-like and drawn in black, while the 
Commodore’s greater colour potential and higher 
resolution allow for finer character detail. Finally, 
the objects present at the location appear: these 
could include food, wine, jewels, keys and 
weapons. Once again, the Spectrum’s 


representations are far less realistic than those of 


the Commodore version. 

The characters then interact with each other, 
and their actions are described in words at the 
bottom of the screen. And this is where you come 
in. The range of actions that the player can 
perform is extensive: you might like to try 
persuading one of the Nordic Gods to part with 
some of his treasure, or you couldtry attacking him 
with a weapon to test your strength. After a while, 
though, you will want to go off and explore new 
territory to seek out the fabled Valhalla. Finding 
the magical objects that will eventually give access 
to this Paradise is not an easy task; many are 
incredibly difficult to lay hands on — and the 
exasperation that this can cause is perhaps a 
limitation of the game. 


Valhalla: For 48K Spectrum, £14.95 
For Commodore 64 £14.95 

Publishers: Legend, Freepost, | Milton Road, 

Cambridge CB4 1UY 
Authors: Graham Asher, Richard Edwards, 
Charles Goodwin, James Learmont, 

Jan Ostler, Andrew Owen, John Peel 

Joysticks: Not required 

Format: Cassette 
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So far in the course we have built up 
subroutines to make use of the high 


resolution capabilities of — the 
Commodore 64. These. have included 
Plotsub and Linesub. Here, we look at a 
routine that will draw circles, given 
the centre co- -ordinates and radius. 





It is impossible to produce a precisely drawn circle 
on a home computer. The accuracy of the 
approximation we can make depends on the 
method used and the length and complexity of the 
final routine. Circle drawing from BAsic usually 
involves calculations using either the sine and 
cosine functions or squares and square roots to 
produce the co-ordinates of points on the 
circumference of the circle to be drawn. Both of 


these methods, however, produce difficulties 


when we try to implement them in machine code, 
so let’s look at an alternative method, which is 
particularly suited to a machine code solution. 

The method we shall use considers the diameter 
of a circle to be divided into an equal number of 
parts, each of width W. At each division we can 
think of a rod that reaches vertically upwards to a 
point C, on the circumference of the circle. The 
diagram shows one such rod, N divisions from the 
left-hand end of the diameter, AB. By joining A 
and B to C we form two right-angled triangles, 
ACD and BCD, as shown on the right. 

Using Pythagoras’s theorem, we can write down 
the following expressions from this diagram: 


AC? = AD? + CD? 
CB? = DB? + CD? 


If we add these equations together we get: 

AC? + CB* = AD? + DB? + 2CD? 
However, it is a special property of circles that 
triangle ABC is also right-angled. So, we can say: 

AC? + CB* = AB? 

Putting this into the left-hand side of the earlier 
equation we get: | 

AB’ = AD? + DB? + 2CD? 


CD corresponds to ‘yup’ — the distance from the 
diameter to the circumference. AD is NXW and 
AB is 2XR, where R is the radius of the circle. 
Substituting these values into the equation and 
rearranging these factors we get: 


2yup? = RY — (NW)? — QR-NWY 
yup* = | 
If we toads to divide the diameter into 64 equal 


xcentre, ycentre 





parts, then W = 2XR/64, which reduces to 
= R/32. Substituting this into the equation: 


yup* = 2RNR/32 — N? R?/32? 
yup* = R*/32? X(64N—N?) 


and finding the square root of both sides gives: 
yup = R/32XSQR(64N — N?) | 


If we start with x = xcentre — R and increment in 
64 equal steps, then at each increment the distance 
up to the circumference will be given by the 
formula we have arrived at, where N is the step 
number. Although this result includes a square 
root, we should note that the expression to be 
Square-rooted is independent of the centre 
co-ordinates or radius of the circle. We can, 
therefore, calculate a table of values for the square 
root function, which gives a solution for each value 
of N from 0 to 64. This needs to be done only once 
and can be incorporated into our program as a 
‘look-up’ table. 

The absolute y co-ordinate for each increment 
of x is: 


ya = ycentre — yup 
We can also make use of the symmetry of the circle 
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to calculate the corresponding y co-ordinate in the 
bottom half of the circle: 


yb = ycentre + yup 
DEVELOPING OUR ROUTINE 


We can now map out the structure of the routine in 
detail. The flowchart shows how each point on the 
circumference can be calculated. We can see that 
the routine should be fairly fast as only one 
multiplication needs to be performed for each 
point plotted. However, there are two slight 
problems with the routine as it stands. First of all, 
we will not produce a continuous circle, only a 
series of points around the circumference. 
Secondly, although this technique produces well- 
defined circles when used from Basic, there are 
inaccuracies when it is done in machine code. 
The first problem can be solved by making use 
of Linesub (see page 419) to join the points with 
short lines, to produce a continuous circle. The 
second problem is due to inaccuracies in the 
calculation of the square root ‘look-up’ table. 
Calculating the values in BAsic and POKEing them 
into a series of bytes set aside for the table means 
that only the integer part of each value is actually 
stored. To get more well-defined circles, we must 
improve the accuracy of the values stored in the 
table. The maximum number to be stored is 32, 
and therefore we can multiply each number by 
eight before storing it, and still use only one byte 
per table entry. 32 is the only number, when 
multiplied by eight, which can’t be held in a single 
byte. To simplify the routine we'll approximate this 
value. Our machine code routine can then divide 
the table value by eight, by performing three LSRs 
(logical shifts right) on it. More importantly, it can 
keep the remainder after division for use in further 
calculations. 


The source code listing sets aside 65 bytes at the 


beginning of the program to store the table, the 
first byte of which is labelled. Subsequent entries 
in the table can be accessed by indexed addressing. 
The source code listing can be entered and 
assembled into memory as usual. However, before 
SAVEing the assembled code, the following BAsIc 
program should be entered and RUN. It will not 
corrupt your object code, as this is located high in 
memory. The program calculates the 65 table 
values required by our Circsub program, 
multiplies these values by eight and POKEs the 
result into the area of memory set aside in your 
machine code program. Once the table creation 
program has been RUN the machine code can be 
SAVEd in the usual way, but ensure that you SAVE 
the table area in with the object code. The table 
starts at SC500. Once this has been done, the ‘look- 
up’ table will be loaded automatically whenever 
you load Circsub. 
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The following program shows how Circsub can be 
used from within a BAsic program. All that is 
required is to specify the centre co-ordinates and 


the radius. The subroutine at line 2000 splits the x 


co-ordinate into LO-byte/HI-byte form, then 
POKEs the specified values to Circsub and makes 


the appropriate SYS call. Note that, as Circsub uses 


Linesub, which in turn uses Plotsub (see page 
337), all three subroutines must be loaded at the 
start of the program. This program draws circles 
with increasing radii across the screen. 





As with the other high resolution subroutines for, 


the Commodore 64, the machine code can also be 
entered as a series of DATA statements if you do not 


have an assembler. The listing below should be 


typed and RUN to load Circsub into memory. Note 
that the Basic loaders for Linesub and Circsub 
should also be loaded and RUN prior to loading the 
demonstration program. As the three routines will 
now be in memory, lines 10, 15 and 20 of the demo 
program should be omitted. Note that the Basic 
loader for Circsub already contains the look-up 
table data and so it is not necessary to RUN the 
‘create table’ program in this case. 
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Room For Manoeuvre 

The company headquarters are 
in Sutton Park, outside Reading: 
_ Audiogenic moved here in April 
1984 from a house in the centre 

_ of Reading that could no longer ~ 
provide enough storage space 


_ Leading Light 

Audiogenic’s Managing Director 

Martin Maynard who founded 

the company as a recording 
‘studio in the early 1970s 





“managing director Martin Maynard as ‘a 


SOUND SUCCESS 





Audiogenic may not be as well known as 
| other software companies, but it has built up 
-a good reputation as a major supplier of 


software for Commodore’ machines. 
Originally merely a tape duplication 
company, Audiogenic now writes and 
distributes software and manufactures 


hardware peripherals. 





Audiogenic is described by its founder ana 
marketing and manufacturing business’. Maynard 
originally worked in the music industry, and 
established Audiogenic in Reading in the early 
1970s as a recording studio and audio tape 
duplication service. In 1978, Audiogenic was 
commissioned by the Southern Electricity Board 
to duplicate a computer data cassette. The 
company’s equipment was modified to cope with 
the demands of producing computer tapes in bulk, 
and Audiogenic signed a contract with 
Commodore to handle software duplication for 
the PET microcomputer. 

The company then took over the marketing and 
distribution of Commodore's cassette catalogue, 
and began selling books, magazines and other 
Commodore-related equipment. After the launch 
of the Vic-20 in 1981, Maynard obtained licences 
to market Vic products developed by American 
software houses. Software manufactured under 
licence still accounts for 80 per cent of the 
Audiogenic catalogue, and represents 85-90 per 
cent of the company’s £1.7 million turnover. 

This emphasis on software marketing, rather 
than in-house production, appears to have been 
very successful, and Maynard estimates that 


Audiogenic has now produced over one million © 
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cassettes. ‘Our strongest point is that we have a 
large catalogue. This diversity means that we can 
understand what’s going on in the market, 
Maynard claims. ‘Having been in the software 
industry for six years, we've seen it all before. Of all 
the software sent out over the last year, 20-30 per 
cent is still on someone's shelf. Writers are losing 
touch with what people want.’ 

This cautious approach, promoting tried and 
tested software, contrasts strongly with the go-for- 
broke tactics employed by many other software 
houses. David Smithson, the Audiogenic product 
manager, points out: “You don’t see us buying 
Porsches. Some companies are Le setting 
themselves up for a fall’ 

Audiogenic now employs 25 people. The 
company’s leading programmer, Dave Middleton 
(writer of the highly rated Magpie database 
package), is employed on a freelance basis. 
Audiogenic tends to concentrate on utility 
software for its in-house programs, rather than 
going for the fast profits associated with the games 
market. As Maynard explains, “Computers will 


always have a games element but that phase is now 


dying and computer software will develop into 
something more useful. When a package is selling 
two to three hundred a month you think “that’s not 
selling very well”, but it will still be selling that 
number in a year’s time.’ 

This does not mean that the company neglects 
the games market entirely. One of Audiogenic’s 
biggest sellers was Motor Mania, and the company 
has recently launched Alice in Videoland for the 
Commodore 64. Developed under licence, this 
game consists of a massive 90 Kbytes of code 
spread over five screens that are loaded from disk 
as the game progresses. 

Shortly after moving into larger premises in 
March 1984, Audiogenic installed updated tape 
duplication equipment. The new machinery 
reproduces a program repeatedly on a continuous 
length of tape, which is cut up and packaged in 
cassette form after duplication. This is both faster 
and more convenient than the old system, which 
duplicated programs onto separate cassettes and 
meant that the company needed to store large 
stocks of blank C10 and C20 cassettes. 

Audiogenic intends to continue its policy of 
distributing products manufactured by other 
companies in the UK and USA. Diversification 
into hardware peripherals has led to the company 
marketing a touch tablet graphics pad that was 
developed by Koala Technologies. Planned 
software projects include a range of cassettes for 
MSX machines and software for the new 
Commodore 16 home computer. 
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